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5 filed September 12, 2003 and entitled ABSTRACTING LINjls TO ELECTRONIC 

RESOURCES IN A NETWORK ENVIRONMENT, which is hereby incorporated herein by 
reference in its entirety. ( 



Technical Field 

The present invention relates to electronic resources and services, and more specifically 
10 to management of links or other pointer objects embedded in electronic resources. 

Background of the Invention 

A primary focus for implementing a network environment is to provide electronic 
resources and services to clients connected to the network. One such electronic resource/service 
is a web page. Web pages are generally understood to be individual electronic documents 
15 making up a website within a client-server network. A server computer delivers an electronic 
resource to a client computer in response to a request issued by the client computer. The request 
specifically identifies the electronic resource by a unique address recognizable to the server 
computer as defining the location of the electronic resource on a given network, such as, for 
example, the Internet or an intranet. 

20 As is known to those skilled in the art, the unique address of a electronic resource is 

referred to as a universal resource locator (or "URL") and may take the following exemplary 
form: http://wvm.webpage.com/path/sub-path/object.htm. A URL is typically divided into three 
constituent parts: a protocol identifier, a domain name and a path; although, the path may not be 
included in a URL in some circumstances. The protocol identifier identifies the application layer 

25 (OSI Reference Model) protocol that is to be used by client computers to render the resource to 
users. The domain name represents the address of the server computer maintaining the 
electronic resource on the network and the path identifies the location of the electronic resource 
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within the server computer. Referring back to the exemplary form noted above, the protocol 
identifier of this URL is "http://," the domain name of this URL is "www. webpage.com" and the 
path of this URL is /path/sub-path/object. htm. A fourth and optional constituent part of the URL 
is a query string containing additional parameters for further specifying the requested resource. 
5 The query string is appended to the URL after the path and is separated from the path by a 
question mark ("?"). 

To request a specific electronic resource, a user selects or inputs the URL associated with 
the electronic resource through a user interface implemented on a client computer. Upon receipt 
of this URL, the server computer retrieves the associated electronic resource from storage and 

10 provides the resource to the client computer for display to the user. While displayed, the 

electronic resource typically includes muhiple information objects embedded in the page and 
arranged in a predefined order. These information objects may include, for example, text 
objects, picture objects, clipart and links to other electronic resources maintained on the same or 
a different server computer maintaining the currently presented electronic resource. As an 

15 illustration, a resource server for a vehicle dealership associated with a particular vehicle 

manufacturer maintains, and thus is operable to serve, i.e., deliver, multiple web pages associated 
with various vehicles and services which may be purchased through the dealership. While being 

as well as hyperlinks that may be selected to request the presentation of other electronic 
20 resources related to each of these vehicles. 

It is very common that an electronic resource may link to, or reference, another electronic 
resource on the same or a different server in order to minimize the duplication of content 
between these pages. In order to establish a link to another electronic resource, the developer of 
an electronic resource under construction declares a reference to the linked resource within the 

25 electronic resource. For example, if the electronic resource under construction is an HTML web 
page, then the developer includes an "href tag" within the HTML file for the web page. The href 
tag specifies the URL of the electronic resource being referenced. Declaration of an href tag is a 
fairly simplistic process that involves manually typing the tag into the electronic resource. 
However, this current approach is not without at least one significant drawback, as described in 

30 the following paragraph. 
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There typically arises a need at some point in time during the life of an electronic 
resource for the developer to change the storage location of the electronic resource due to factors 
such as, but not limited to, load balancing of servers and server maintenance. If, for any reason, 
a referenced electronic resource moves from one location on a server computer to another 
5 location on that or another server computer, the URL of the referenced electronic resource 
changes accordingly. As such, ail current references to that resource that may have been 
manually incorporated into other electronic resources are no longer valid and must be amended 
in order for users to properly access the relocated resource via the corresponding link. The 
otherwise simplistic task of revising each reference to the relocated resource becomes a daunting, 
10 time-consuming effort if the re-located web page is referenced in a large number of other 
electronic resources. 

It is with respect to these and other considerations that the present invention has been 

made. 

Summary of the Invention 

15 In accordance with the present invention, the above and other problems are solved by 

preparing electronic resources for delivery to client computers in a network environment. In 
accordance with an embodiment, link identifiers are declared in the electronic resources for each 
reference to another resource. Upon reception of a request for delivery of an electronic resource, 
a server computer retrieves the requested electronic resource from storage. Link identifiers are 

20 not recognizable to client computers, and therefore the server computer analyzes all link 

identifiers in the electronic resource in order to abstract all links to resources referenced in the 
requested resource. This abstraction process yields a network address link for each detected link 
identifier that the server computer incorporates into the requested electronic resource, thereby 
preparing the resource for use by the requesting client computer. 

25 In an embodiment, the electronic resource is prepared for such delivery by a process of 

acts or operations performed according to an embodiment of the invention. First, the electronic 
resource is examined for a link tag corresponding to the link reference. The link tag comprises 
the link identifier that is used to determine the network location of the referenced electronic 
resource. The link identifier is extracted and then used to identify a unique network address 
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corresponding to the network location. Once identified, the unique network address is 
incorporated into the electronic resource. The electronic resource is then ready for transmission 
to the client computer. 

The present invention is also embodied in a system for preparing an electronic resource 
5 for delivery to client computer in a network environment. When rendered on a display device on 
the client computer, the electronic resource presents a graphical representation of a reference link 
to another electronic resource. The system includes an index file having a plurality of link 
identifiers associated with electronic resources maintained within the network environment. The 
index file relates each of the link identifiers to an entry of address information indirectly 
10 specifying a unique location within the network environment for each of these electronic 
resources. 

The system also includes a processing module that retrieves the requested electronic 
resource fi'om storage and extracts fi'om the retrieved electronic resource the link identifier 
corresponding to the referenced electronic resource. The link identifier is used by the processing 
15 module to identify a network location for the referenced electronic resource. More specifically, 
the processing module references the index file with the link identifier in order to initiate the 
process for identifying the unique address of this network location. 

In accordance with yet another embodiment, the present invention relates to method for 
developing an electronic resource for use within a network environment. First, a plurality of 

20 instructions for rendering the electronic resource for presentation to users is defined within the 
electronic resource. Then, a reference to another electronic resource is declaring within the 
plurality of instructions. The reference includes a link identifier associated with a network 
location for the referenced electronic resource. A reference file is created and maps the link 
identifier to a unique address corresponding to the network locafion on which the referenced 

25 electronic resource is stored. After the electronic resource has been developed and deployed on a 
server computer, the server uses the reference file and the link identifier to abstract the unique 
address of the network location in order to prepare the electronic resource for delivery to a client 
computer. 

The invention may be implemented as a computer process, a computing system or as an 
30 article of manufacture such as a computer program product or computer readable media. The 
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computer program product may be a computer storage media readable by a computer system and 
encoding a computer program of instructions for executing a computer process. The computer 
program product may also be a propagated signal on a carrier readable by a computing system 
and encoding a computer program of instructions for executing a computer process. 

5 The referencing within an electronic resource of other electronic resources using link 

identifiers, rather than a hard-coded unique address, allows for a more efficient deployment of 
multiple electronic resources referencing an individual electronic resource on a server computer. 
If, for any reason, the location of a referenced resource is changed, the reference file is modified 
to accommodate this change, and as such, the code of each referencing electronic resource does 
10 not require modifying. 

These and various other features as well as advantages, which characterize the present 
invention, will be apparent fi^om a reading of the following detailed description and a review of 
the associated drawings. 

Brief Description of the Drawings 

15 Having thus described the invention in general terms, reference will now be made to the 

accompanying drawings, which are not necessarily drawn to scale, and wherein: 

FIG. 1 illustrates an exemplary environment in which the present invention may be 
practiced, the environment embodying a client-server network wherein electronic resources are 
served to a client computer by a server computer. 
20 FIG. 2 depicts a logical illustration of electronic resources having an embedded reference 

link to another electronic resource in accordance with an embodiment of the present invention. 

FIG. 3 shows a computer system that may be used according to particular aspects of the 
present invention. 

FIG. 4 is an exemplary code listing for an electronic resource according to an 
25 embodiment of the invention. 

FIG. 5 shows a system for preparing an electronic resource for transmission to a client 
computer for subsequent rendering of the resource on an electronic resource browser in 
accordance with an embodiment of the present invention. 
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FIG. 6 depicts an exemplary listing for establishing a relation between identifiers for 
electronic resources and the storage locations of the resources in accordance with an embodiment 
of the invention. 

FIG. 7 depicts a first object resuhing from the interpretation and compilation of the 
5 exemplary listing of FIG. 6. 

FIG. 8 depicts a second object resulting from the interpretation and compilation of the 
exemplary listing of FIG. 6. 

FIG. 9 is a flow diagram that illustrates operational characteristics of a process for 
preparing an electronic resource for delivery to a client computer in accordance with an 
1 0 embodiment of the present invention. 

FIG. 10 is a flow diagram that illustrates operational characteristics of the preparation 
process of FIG. 9 in more detail in accordance with an embodiment of the present invention. 

FIG. 11 is a flow diagram that illustrates operational characteristics for building the 
system of FIG. 5 in accordance with embodiments of the present invention. 

15 Detailed Description of the Invention 

The present invention will now be described more fully hereinafter with reference to the 
accompanying drawings, in which embodiments of the invention are shown. This invention may, 
however, be embodied in many different forms and should not be construed as limited to the 
embodiments set forth herein; rather, these embodiments are provided so that this disclosure will 

20 be thorough and complete, and will fully convey the scope of the invention to those skilled in the 
art. Like numbers refer to like elements throughout. 

Referring to FIG. 1, an exemplary environment in which the present invention is 
practiced is shown in accordance with an embodiment. More specifically, FIG. 1 depicts a 
client-server network having a server cluster 100 and a plurality of client computers 108. The 

25 server cluster 100 is a collection of server computers 104, 105 that maintains at least one 

electronic resource. The client computer 108 provides a user interface through which electronic 
resources are presented to users. One of skill in the art will appreciate that the client-server 
network shown in FIG. 1 is illustrative only, and that this network may include any number of 
client computers 108 and the server cluster 100 may include any number or server computers 

30 104, 105. 
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An electronic resource is generally defined as a machine-readable form of an electronic 
file, such as a web page or other electronic document, a sound file, a movie file, or any other file, 
which may be transmitted between computers across a network environment. In order to clearly 
illustrate embodiments of the present invention, the exemplary electronic resources shown and 
5 described herein are defined as being the machine readable forms of websites and web pages. 
Management (e.g., creation, implementation and modification) by a group of server computers, 
such as the server cluster 100, over a plurality of web pages making up a website is referred to 
herein as web site "maintenance." As such, the server cluster 100 maintains at least one 
exemplary website having a plurality of associated web pages. Those skilled in the art will 
10 recognize that the present invention is applicable to all other forms of electronic resources as 
well. 

In general, the server cluster 100 is responsible for delivering electronic resources 
maintained thereon to client computers (e.g., 108). In response to receiving a request for an 
electronic resource, a server (e.g., 104 and 105) within the server cluster 100 performs a resource 

15 retrieval process in order to fetch the associated resource fi"om storage. As known to those 

skilled in the art, there are numerous implementations that may be used to build and maintain a 
server cluster. Any known implementation for building and maintaining a server cluster may be 
chosen for the sep/er cluster 100 on which the present invention is implemented. However, for 
illustrative purposes, and by no means a matter of limitation, the server cluster 100 administers 

20 the fetching of electronic resources through a two-tier server implementation. In this 

embodiment, the server cluster 100 includes a primary server computer 104, also referred to as a 
"resource server," and a plurality of secondary, or "back-end," server computers 105. 

The resource server 1 04 is responsible for preparing the electronic resources maintained 
on the cluster 100 for use by client computers (e.g., 108). The resource server 104 also interacts 

25 with the client computer 108 to receive URL requests fi-om the client computer 108 and to send 
prepared electronic resources corresponding to the URL requests to the client computer 108 for 
presentation to users. The resource server 104 is communicatively connected to each of the 
back-end servers 105, which are responsible for retrieving the electronic resource corresponding 
to the URL requests fi"om a database 106 and subsequently providing their electronic resource to 

30 the resource server 104 for preparation and transmission to the client computer 108. 
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The databases 106 are shown in FIG. 1 as being separate storage modules 
communicatively accessible to each of the back-end servers 105. However, it should be 
appreciated that the databases 106 may instead be storage components maintained on the back- 
end servers 105. As such, the temi "back-end server" may be used to refer to the combination of 
5 a server computer 105 and an associated database 106. As is known to those skilled in the art of 
information services, the implementation is a matter of choice. 

The client computer 108 includes a display device 1 10 and one or more software 
applications that provide a user interface for viewing web pages and other electronic documents 
rendered from electronic resources sent to the client computer 108 from the resource server 104. 

10 In an embodiment, the user interface is an electronic resource browser 112 (hereinafter, 
"browser"), as shown in FIG. 1 . The browser 1 12 is displayed on the display device 110. 
Exemplary software application programs operable for rendering a browser 1 12 on the display 
device 1 10 include, for example, word processing application programs, electronic mail 
application programs, WWW browsing application programs and the like. For illustration 

15 purposes, the browser 112 shown and described in FIG. 1 is operable to implement/execute 
prepared electronic resources sent from the resource server 104 to render web pages 120 on the 
display device 110. 

In an embodiment, the browser 112 includes a document title display 1 14, a toolbar 116 a 
navigation bar 1 18 and a document display region 121. The document display page 121 is a 

20 display region on the browser 1 12 on which web pages 120 are presented to users for viewing 
and manipulation. The browser 1 12 displays the title 1 15 of the web page 120 being presented in 
the document title display 114. The toolbar 116 includes various menu items selectable by the 
user for controlling the operations of the browser 112. The navigation bar 118 includes icons 
selectable by the user for navigating through the various web pages of the World Wide Web 

25 (WWW). Both toolbars 1 16 and navigation bars 1 18 are known in the art and therefore not 
described in greater detail herein. 

The web pages 120 rendered on the display device 110 each include various information 
objects 122 such as, the text and clipart shown in FIG. 1. The web pages 120 may also include 
another type of information object referred to as a reference link 124, which are hyperlinks 

30 selectable by users to request the presentation of other web pages 120 (referred to herein as 

"referenced web pages") in the document display region 121 of the browser 112. In response to 
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selection of one of these reference links 124, the browser formulates a URL request specifying 
the URL associated with the reference link 124 and forwards this request onto the appropriate 
resource server. Of course, electronic resources other than web pages 120 may be referenced on 
the web page 120 through the browser 1 12. 
5 The referenced electronic resource may be a resource that is maintained by either the 

server cluster 100 or another server cluster. That is, the referenced electronic resource may be 
"internal to" or "external to" the server cluster 100. If the referenced electronic resource is 
"internal to" the server cluster 100, the electronic resource is thus stored in one of the databases 
106 and maintained by one of the back-end servers 105. As such, the URL request is sent to the 

10 resource server 104. If, however, the referenced electronic resource 120 is external to the server 
cluster 100, i.e., accessible through a resource server not part of the server cluster 100, then the 
URL request is sent to this other resource server for processing. 

In accordance with an embodiment and in response to receiving a URL request issued by 
a client computer 104, the resource server 104 analyzes the URL request to determine the 

15 appropriate back-end server 105 responsible for maintaining the associated electronic resource. 
The resource server 104 then issues a command to this back-end server 105 requesting the 
electronic resource. The back-end server 105 accesses the database 106 on which this electronic 
resource is stored, retrieves the electronic resource and then transmits the electronic resource to 
the resource server 104. The resource server 104 analyzes the electronic resource and then 

20 prepares the electronic resource for transmission to the client computer 108. 

In accordance with another embodiment, the use of back-end servers 105 is relinquished 
in favor of the resource server 104 storing all electronic resources maintained by the server 
cluster 100. In this embodiment, the resource server 104 accesses and retrieves from local 
storage electronic resources identified in URL requests from the client computer 108. 

25 A communications network 102 provides a communication connection between the 

server cluster 100 and the client computer 108. As such, a prepared electronic resource is sent 
from the resource server 104 to the client computer 108 over this communications network 102. 
It should be appreciated that the communications network 102 may be any type of network 
known to those skilled in the art or an equivalence thereto. Some exemplary networks include, 

30 without limitation, the Internet, an Intranet, a private line network, or even a direct 

communication link between the client computer 108 and the server computer 104. It should 
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also be understood that the communications network 102 may utilize any number of 
communication technologies depending on functions required by the embodiment. Examples of 
specific technologies used in conmiunications networks 102 contemplated include without 
limitation terrestrial, cellular, satellite, short-wave, and microwave connections to the Internet, 
5 directly between facilities using modems or other interface devices, or through other 

communications networks, such as local area networks or wide area networks. Any combination 
of these or other communications networks may be utilized and remain within the scope of the 
invention. 

The resource server 104 and the client computer 108 communicatively connect to the 

10 communications network 102 by way of a server communication link 103 and a client 

communication link 107, respectfully. In an embodiment, the communication links 105 and 107 
are implemented as wired communication medium, such as, without limitation, copper-based or 
fiber optic communication media. In another embodiment, the communication links 105 and 107 
are implemented as wireless communication medium, such as, without limitation, infi-ared, sonic 

15 or radio communication. 

As noted above, the term "electronic resource" is being used herein to refer to a machine- 
readable form for web pages and other types of electronic files. The electronic resources of the 
present invention, however, are only in a form readable by the resource server 104, and not the 
client computer 108 while stored on the server cluster 100. Thus, prior to being sent to the client 

20 computer 108, an electronic resource is manipulated, or processed by the resource server 104 
into a modified format that the client computer 108 can read. The modification of an electronic 
resource in this manner is referred to as "preparing" the resource for use by the client computer 
108. It should also be noted that the format in which an electronic resource is "readable" by a 
client computer 108 depends on the browser 1 12 or other user interface display program 

25 implemented on the client computer 108. Exemplary resource formats that may be readable, or 
recognizable, to the browser 1 12, and thus the client computer 108, include, but are not limited 
to, Hypertext Markup Language (HTML), Active Server Page (ASP), ASPX and Extensible 
Markup Language (XML). Each of these formats are known to those of skill in the art, and 
therefore not described in further detail herein. Although electronic resources may be stored in a 

30 database 106 in one of these exemplary formats, an embodiment of the invention contemplates 
that an electronic resource includes one or more executable routines that are not recognizable to 
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the client computer 108. As such, preparation of the electronic resource by the resource server 
104 includes executing any such routines. A process and system for preparing an electronic 
resource according to this embodiment is described in more detail in connection with FIGS. 4- 
10. 

5 Referring now to FIG. 2, a logical representation of plurality of web pages 120 (Web 

Pages A, B, C and D) referencing another web page 120 (Web Page E) are shown according to 
the environment depicted in FIG. 1. The web pages 120 each include a plurality of information 
objects 122 and reference links 124, which are both shown logically using square blocks. Web 
Pages A, B, C and D 120 each include a reference link 124 to Web Page E 120. When selected 
10 by a user, the reference link 124 invokes a process for displaying the referenced web page E 120 
to the user. As is known to those of skilled in the art, a browser- (or client-) recognizable format 
for an electronic resource definition corresponding to an exemplary reference link is shown as 
follows: 

<a href="http://www.uspto.gov /siteindx.htm">, wherein various other parameters may 

1 5 follow the URL specification enclosed by quotation marks. 

It should be appreciated that reference links 124 contained in Web Pages A, B, C and D 
120 may either reference internal and/or external links. For example, Web Pages A and B 120 
may be maintained on the same server cluster 100 as Web Page E 120, while Web Pages C and 
D 120 are maintained on a different server cluster 100. Regardless of the implementation, the 

20 browsers 1 12 presenting each of these web pages 120 to a user operate in substantially the same 
manner when the reference link 124 to Web Page E 120 is selected: each of these browsers 1 12 
creates a URL request specifying the URL for Web Page E and subsequently transmits this 
request to the resource server 104 of the server cluster 100 maintaining Web Page E. 

FIG. 3 illustrates an example of a suitable computing system environment on which 

25 embodiments of the invention may be implemented. This system 104 is representative of one 
that may be used to function as a server providing a website service. In its most basic 
configuration, system 104 includes at least one processing unit 302 and memory 304. Depending 
on the exact configuration and type of computing device, memory 304 may be volatile (such as 
RAM), non-volatile (such as ROM, flash memory, etc.) or some combination of the two. This 

30 most basic configuration is illustrated in FIG. 3 by dashed line 306. 
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In addition to the memory 304, the system 104 may include at least one other form of 
computer-readable media. Computer readable media can be any available media that can be 
accessed by the system 104. By way of example, and not limitation, computer-readable media 
might comprise computer storage media and communication media. 
5 Computer storage media includes volatile and nonvolatile, removable and non-removable 

media implemented in any method or technology for storage of information such as computer 
readable instructions, data structures, program modules or other data. Memory 304, removable 
storage 308 and non-removable storage 310 are all examples of computer storage media. 
Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or 

10 other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, 
magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or 
any other medium which can be used to store the desired information and which can accessed by 
system 104. Any such computer storage media may be part of system 104, 

System 104 may also contain a communications connection(s) 312 that allow the system 

15 to communicate with other devices. The communications connection(s) 312 is an example of 
communication media. Communication media typically embodies computer readable 
instructions, data structures, program modules or other data in a modulated data signal such as a 
carrier wave or other transport mechanism and includes any information delivery media. The 
term "modulated data signal" means a signal that has one or more of its characteristics set or 

20 changed in such a manner as to encode information in the signal. By way of example, and not 
limitation, communication media includes wired media such as a wired network or direct-wired 
connection, and wireless media such as acoustic, RF, infrared and other wireless media. The 
term computer readable media as used herein includes both storage media and communication 
media. 

25 In accordance with an embodiment, the system 104 includes peripheral devices, such as 

input device(s) 314 and/or output device(s) 316. Exemplary input devices 314 include, without 
limitation, keyboards, computer mice, pens, or styluses, voice input devices, tactile input devices 
and the like. Exemplary output device(s) 316 include, without limitation, displays, speakers, and 
printers. Each of these "peripheral devices" are well known in the art and, therefore, not 

30 described in detail herein. 
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With the computing environment in mind, the following figures (FIGS. 4-1 1) are 
described with reference to logical operations being performed to implement processes 
embodying various embodiments of the present invention. These logical operations are 
implemented (1) as a sequence of computer implemented steps or program modules running on a 
5 computing system and/or (2) as interconnected machine logic circuits or circuit modules within 
the computing system. The implementation is a matter of choice dependent on the performance 
requirements of the computing system implementing the invention. Accordingly, the logical 
operations making up the embodiments of the present invention described herein are referred to 
variously as operations, structural devices, acts or modules. It will be recognized by one skilled 
10 in the art that these operations, structural devices, acts and modules may be implemented in 
software, in firmware, in special purpose digital logic, and any combination thereof without 
deviating from the spirit and scope of the present invention as recited within the claims attached 
hereto. 

Turning now to FIG. 4, a portion of an exemplary code listing for an electronic resource 
15 400 is shown in accordance with an embodiment of the present invention. The listing for this 
electronic resource 400 is in native format with respect to the server cluster 100 on which the 
electronic resource 400 is maintained. As such, the electronic resource 400 that has not yet been 
prepared by the resource ser/er 104 for transmission to and use by the client computer 108. 

The listing for this exemplary electronic resource 400 begins with an HTML start tag 402 
20 that identifies the overall format for the electronic resource as being HTML. The HTML start 
tag 402 also defines the beginning of the code that corresponds to the actual substance and 
content of the electronic resource 400. An HTML end tag 41 1 indicates the end of this code 
corresponding to the actual substance and content of the electronic resource 400. A header 
region 404 follows the HTML start tag 402 and is bounded by a start header tag 403 and an end 
25 header tag 405. The header region 404 describes various aspects of the electronic resource 400 
such as, without limitation, metatags and a description of the electronic resource 400. As known 
to those skilled in the art, metatags are used to by search engines to identify electronic resources 
relative to a query search being performed by the engine. 

Following the header region 404 is a body region 406, which is bounded by a start body 
30 tag 407 and an end body tag 409. The body region 406 specifies the content and structure of the 
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electronic resource 400. For example, the body region 406 is shown in FIG. 4 as including an 
object tag 408 that defines the background of this electronic resource 400 when rendered as a 
web page 120 by the browser 112. Also included in the body region 406 of the listing for this 
electronic resource 400 is a link tag 410 that specifies, in accordance with an embodiment of the 

5 present invention, a particular reference link 124 that will be displayed on the rendered web page 
120, In this embodiment, wherein the electronic resource 400 is invoked/executed to render a 
web page 120, the link tag 410 is a definition that is used internally within the server cluster 100 
to determine the URL that is to be specified in an href tag that will be incorporated into the 
electronic resource 400 during preparation for transmission to the client computer 108. 

10 The link tag 410 includes a tag identifier 412, a control object 414 and a link identifier 

418, which is also referred to as a hyperlink identifier, or "hlid." The tag identifier 412 is the 
parameter of the link tag 410 that indicates to the resource server 104 that this definition is a link 
tag 410. In a more specific embodiment, the tag identifier 412 is a namespace on the resource 
server 400 that is associated with various object classes. The control object 414 is a particular 

1 5 object class that resides in the namespace identified by the tag identifier 412. After the resource 
server 104 detects the link tag 410 and determines the namespace associated with the tag 
identifier 412, the resource server 104 instantiates the control object 414 to execute a routine for 
identifying the URL corresponding to the electronic resource being referenced. The link 
identifier 418 is defined as a property of the control object 414, and thus, used by the executed 

20 routine to identify the appropriate URL corresponding to the electronic resource being 
referenced. Such a routine is described in more detail in FIG. 10 in accordance with an 
embodiment of the present invention. After this URL is identified, the resource server 104 
replaces the link tag 410 with a client-readable declaration (e.g. an href tag) specifying the 
identified URL, thereby preparing this electronic resource 400 for use by the client computer 

25 108. 

Referring now to FIG. 5, a system 500 for preparing an electronic resource for use by a 
client computer 108 is shown in accordance with an embodiment of the present invention. In 
this embodiment, the preparation system 500 embodies a collection of software modules created 
on computer system 501 in a build, or development, lab and implemented, or deployed, on the 
30 resource server 104. Those skilled in the art will recognize that various alternatives to the 
system 500 shown in FIG. 5 are contemplated within the scope of the present invention. For 
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example, the collection of software modules may be created as well as implemented on the 
resource server 104, thereby removing the necessity for the computer system 501. Additionally, 
the software modules may be created and/or implemented on any one of the back-end servers 
105 or on a combination of one or more back-end servers 105 and the resource server 104. 
5 Further, the system 500 may embody a collection of firmware or circuit logic modules alone or 
operating in combination with the software modules. 

Various software modules of the preparation system 500 include a link source file 502, a 
compiler 504, a link identification index 506 and an associated data structure 508, and a 
configuration module 509, The link source file 502, which is also referred to herein as a 

10 "reference file," is created by the developer(s) of the electronic resources maintained on the 
server cluster 100 to be a global listing of link identifiers 418 associated with each electronic 
resource referenced by at least one other electronic resource maintained by the cluster 100. The 
link source file 502 maps each link idenfifier 418 to information corresponding to the URL of 
each referenced electronic resource both internal and external to the server cluster 100. In the 

15 embodiment shown in FIG. 5, the link source file 502 is created on the computing system 501, 
which resides in a build lab. Once created, the link source file 502 is compiled by the compiler 
504, which is a software module implemented on the computing system 501 . Alternatively, the 
compiler 504 may reside on the resource server 104, and as such, the link source file 502 is 
loaded into the resource server 104 for compilation and subsequent deployment thereon. Once 

20 compiled, the resulting link identification index 506 and associated data structure 508 are placed 
within the resource server 104 for implementation thereon. 

With reference now to FIG. 7, an exemplary code listing for a link source file 502 is 
shown in accordance with an embodiment of the present invention. In this embodiment, the link 
source file 502 is a text file. It should be appreciated, however, that the link source file 502 may 
25 be created in any similar file format, including, without limitation, any word processing or 

spreadsheet format, any programming language format, or in XML format. The link source file 
502 includes a comments portion 504, a declaration portion 506 and a definition portion 508. 

The comments portion 504 is a portion of the link source file 502 that contains notes and 
descriptions of the fiinctionality of the file 502. Developers include this conmients portion 504 
30 in order to provide those reading the file 502 with an understanding of exactly what the code is to 
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be used for. Each of the comments in the comments portion 504 are preceded by a comment 
identifier, such as, for example, the "#" symbol shown in FIG. 6. 

The declaration portion of the link source file 502 defines the various service classes 510 
implemented on the server cluster 100. In the listing shown in FIG. 6, exemplary service classes 
5 are "EXTERNAL," SAMPLESERVl," "SAMPLESERV2," SAMPLESERV3," and "LOCAL." 
The declaration portion 506 of the link source file 502 includes a specific definition of each 
service class 510 implemented on the server cluster 100 and a specific definition corresponding 
to all service classes 510 external to the server cluster 100. With the exception of the 
EXTERNAL service class, each of the service classes 510 represent a particular entity internal to 

10 the server cluster 100. These particular entities may be physical machines, i.e., back-end servers 
105, or virtual machines operating on the back-end servers 105. The EXTERNAL service class 
represents all particular entities extemal to the server cluster. The LOCAL service class 
represents all particular entities on the resource server 104 or a virtual machine operating on the 
resource server 104. Each of the service classes 510 correspond to a specific protocol identifier 

15 and domain name assigned to each particular entity. This protocol identifier and domain name 
forms the base portion of a URL for each electronic resource maintained on the associated entity. 

The definition portion 508 of the link source file 502 includes a multitude of internal 
specifications 513 mapping the link identifiers 418 incorporated into at least one electronic 
resource maintained on the server cluster 100 to a specific service class 510 and a specific path 

20 518 relative to that service class 510. In cases where the service is an internal service, i.e., the 
service class is not "EXTERNAL," the path 518 is a hierarchical constituent path specifying the 
location of the electronic resource within the directory/sub-directory file system of the particular 
machine corresponding to the service. In cases where the service class is "EXTERNAL," the 
path 518 is the entire URL for the referenced electronic resource. The internal specifications 513 

25 may also define a query string 520 for each of these link identifiers 514. This optional query 

string represents a collection of parameterized values which are to be included in the URL for the 
electronic resource being referenced by the link identifier 418. 

In an embodiment, the link source file 502 is a text file that is not readable to the resource 
server 104. Such an embodiment is shown in FIG. 5, wherein the link source file 502 is 
30 interpreted and compiled by the compiler 504 to transition the information defined in the file 502 
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into a form readable by the resource server 104. The resulting output of the compiler 504 are the 
link identification index 506 and the associated data structure 508, which are used by the 
resource server 104 in conjunction with the configuration module 509 to match a link identifier 
418 to a particular URL for an electronic resource being referenced. 

5 Turning now to FIG. 7, an exemplary listing of the link identification index 506 

corresponding to the exemplary link source file 502 is shown in accordance with an embodiment 
of the present invention. In particular, the link identification index 506 is one of the two 
resulting objects created by compiling the link source file 502, the other object being the data 
structure 508 associated with the link identification index. The link identification index 506 and 
10 the associated data structure 508 are collectively used by the resource server 104 to identify the 
URL corresponding to the electronic resource being referenced by the link identifier 418. 

The link identification index 506 includes a class definition 522 specifying the class to 
which this object belongs. As such, the class of the link identificafion index 522 is "hlid," which 
as noted above represents an acronym for hyperlink identifier. Following the class definition 

15 522 is a listing of each link identifier 418 mapped to a specific index pointer 524, which in this 
embodiment is represented with an integer. With reference to FIG. 8, the index pointers 524 
each point to an entry 528 specified in the associated data structure 508. The entry 528 in the 
data structure 528 maps each index pointer 524 to the service class 510 and path 518 that were 
defined to correspond to the corresponding link identifier 418 in the link source file 502 at the 

20 time that the file was interpreted and compiled by the compiler 504. 

The configuration module 509 is the portion of the preparation system 500 that analyzes 
the service class 510 for a particular link identifier 418 to determine the URL corresponding to 
that service class 500. The configuration module 509 may take any number of forms, including, 
for example, a searchable text or XML file that maps service classes 510 to domain names and 

25 software applications designed specifically to process a service class 510 and render therefi-om 
the corresponding domain name. Such an application program is described in detail in 

commonly assigned U.S. Patent Application No. (Attorney Docket No. 

010756.104505), filed on and entitled, "SYSTEM AND METHODS FOR SHARING 

CONFIGURATION INFORMATION WITH MULTIPLE PROCESSES VIA SHARED 

30 MEMORY," the subject matter of which is incorporated by reference into this application. 
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The use of the identification index 506, the associated data structure 508 and the 
configuration module 509 by the web server 104 to prepare the electronic resource 400 of FIG. 4 
for transmission to and use by a requesting client computer 108 is now illustrated in accordance 
with an embodiment of the present invention. The resource server 104 first detects the tag 
5 identifier 412 and then extracts from link tag definition 410 the link identifier 418. The resource 
server 104 then references the link identification index 506 to determine the specific index 
pointer 524 associated with the extracted link identifier 418. The resource server 104 then 
references the appropriate entry 528 in the associated data structure 508 based on the index 
pointer 524 determined for the extracted link identifier 418. The resource server 104 first reads 
10 the service class 510 fi-om the entry 528 and then inputs the service class 510 into the 
configuration module 509, which outputs the protocol identifier and the domain name 
corresponding to the service classification 510. The domain name is appended to the protocol 
identifier to form the base portion of the URL corresponding to the link identifier. 

After the protocol identifier and domain name have been determined, the resource server 
15 1 04 again references the entry 528 and reads therefi"om the path 5 1 8 associated with the index 
pointer 524 determined for the extracted link identifier 418. The resource server 104 appends 
this path 518 to the determined domain name to yield, and thus identify, the URL corresponding 
to the link identifier 418. Finally, the resource ser/er 104 replaces the linJc tag 410 with an h_ref 
tag specifying the identified URL. 

20 Referring more specifically to the exemplary definitions of FIGS. 7 and 8, assuming the 

link identifier 418 to be "Apple," the index pointer 524 is thus "0." The service class 510 
corresponding to an index of "0" is "SERVl" and the associated path is 
"/fruit/northamerica.aspx." For purposes of illustration only, if the configuration module 509 
were to determine that the protocol identifier and domain name corresponding to the service 

25 "SERVl " is "http://www.fiiiitsworld.com," the URL for the electronic resource being identified 
in this example is "http://www.fiaiitsworld.com/fruit/northamerica.aspx." 

Referring now to FIG. 9, a flow diagram illustrating operational characteristics 
embodied in a process 900 for managing ("management process") delivery of electronic 
resources to client computers is shown in accordance with an embodiment of the present 
30 invention. To fiirther illustrate the embodiments described above, the management process 900 
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is described as being performed by the resource server 104 in response to the server 104 
receiving a URL request issued by the client computer 108. As such, the management process 
900 is described as being used to (1) determine whether the electronic resource corresponding to 
the URL includes a link tag 410, and if so, (2) convert the link tag 410 to a format readable by 
5 the client computer 108. It should be appreciated that this process 900 may be performed 

multiple times, either simultaneously or sequentially, to perform one or both of these functions. 
That is, although only a single iteration of this process 900 is described herein, it is contemplated 
that multiple iterations are v^arranted. 

The management process 900 is performed using a flov^ of operations (''operation flow") 
10 beginning with a start operation 902 and concluding with a terminate operation 914. The start 
operation 902 is initiated when the server cluster 100 is deployed and the resource server 104 is 
operational to receive URL requests. From the start operation 902, the operation flow passes to a 
receive operation 904. 

The receive operation 904 awaits reception of the URL request from the client computer 
15 108. Once the URL request is received, the receive operation 904 extracts the URL specified in 
the request and the operation flow passes to a retrieve operation 906. The retrieve operation 906 
retrieves the electronic resource corresponding to the received URL from storage. In an 
embodiment, this requested resource is stored in the resource server 104. In another 
embodiment, this resource server 104 may be stored on a back-end server 105. In this 
20 embodiment, the retrieve operation 906 identifies the back-end server 105 maintaining the 

electronic resource corresponding to the received URL. The retrieve operation 906 then sends to 
the identified back-end server 105 a request for a copy of the electronic resource identified by the 
URL. The retrieve operation 906 then awaits the arrival of the copied electronic resource. Upon 
receiving the copied electronic resource, the operation flow passes to the examine operation 908. 

25 The examine operation 908 parses through the retrieved electronic resource to determine 

whether any link tags 410 are included therein. A link tag 410 is defined herein as a definition 
included in the electronic resource for use in identifying a current URL corresponding to a 
specific reference link 124. In an embodiment, the examine operafion 908 detects a link tag 410 
within the electronic resource by searching for and identifying a tag identifier 412 declared 

30 therein. If the electronic resource does not contain any link tags 410, then the operation flow 
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passes to the transmit operation 912. In this case, the electronic resource is currently in a format 
recognizable to the client computer 108. The transmit operation 912 serves the electronic 
resource to the client computer 108 for rendering to a user. After the transmit operation 912 is 
complete, the operation flow concludes at the terminate operation 914. 

5 If the examine operation 908 detects a link tag 410 contained in the electronic resource, 

the operation flow passes to the identify operation 910. The identify operation 910 utilizes the 
link identifier 418 included within the link tag definition to identify the URL corresponding to 
the requested electronic resource. Embodiments of such a process are shown and described in 
connection with FIG. 10. After the identify operation 910 has identified the URL corresponding 

10 to the requested electronic resource, the operation flow passes to an incorporate operation 911. 
The incorporate operation 911 replaces the link tag 410 with a client-readable definition (e.g., an 
href tag) specifying the identified URL, thereby placing the declaration corresponding to the 
reference link 124 into a format readable by the client computer 108. From the incorporate 
operation 91 1, the operation flow passes back to the examine operation 908, which continues 

15 examining the electronic resource for another link tag 410. If the examine operation 908 detects 
another link tag 410, the operation flow passes to the identity operation 910 and continues as 
previously described. Otherwise, the operation flow passes to the transmit operation 912, which 
serves the prepared electronic resource to the client computer 108 for rendering to a user= 

FIG. 10 illustrates in more detail embodiments of the identify operation 910 and the 
20 incorporate operation 91 1 of the preparation process 900. As such, the operational components 
depicted in FIG. 10 are shown as a process 1000 for abstracting (hereinafter, "abstraction 
process") a link tag 410 into a client readable declaration specifying the unique network address 
for a referenced electronic resource. As noted above, the link tag 410 includes a control object 
414 that the resource server 104 instantiates to execute a routine for mapping the link identifier 
25 418 specified in the link tag 410 to a URL. The instantiated control object 414 may execute this 
routine on either the resource server 104 or one of the back-end servers 105, or on a combination 
of both. 

The abstraction process 1000 is performed using an operation flow beginning with a start 
operation 1002 and concluding with a terminate operation 1018. The start operation 1002 is 
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initiated after the examine operation 908 detects a link tag 410 within a retrieved electronic 
resource. From the start operation 1002, the operation flow passes to a retrieve operation 1004. 

The retrieve operation 1004 first extracts the link identifier 418 from the link tag 410. 
The retrieve operation 1004 then accesses the link identification index 506 and retrieves from the 
5 index 506 the index pointer 524 mapped to the extracted link identifier 418. After this index 
pointer 524 has been retrieved by the retrieve operation 1004, the operation flow passes to an 
extract operation 1006. The index pointer 524 points to an entry 528 of the associated data 
structure 508 that corresponds to the extracted link identifier 506. As described with reference to 
FIG. 8, this entry 528 includes both a service class 510 and a path 518 corresponding to the 
10 referenced electronic resource. The extract operation 1006 extracts from this entry 528 the 
service class 510 specified in the entry 528. 

From the extract operation 1006, the operation flow passes to a query operation 1008. 
The query operation 1008 evaluates the extracted service class 510 to determine whether the 
service class 510 is implemented internal or external to the server cluster 100. hi an 

15 embodiment, service class 510 named "EXTERNAL" refers to particular entities implemented 
on an external server cluster. If the service class 510 is "EXTERNAL," the operation flow is 
passed to a identify operation 1010. The identify operation 1010 retrieves the path 518 specified 
in the entry 528 of the associated data structure 508 that corresponds to the extracted link 
identifier 506. This retrieved path 518 is then identified to be the URL, inclusive of the protocol 

20 identifier, domain name, path and query string (if any), corresponding to the link reference 124. 
From the identify operation 1010, the operation flow passes to an incorporate operation 1016, 
which is described in greater detail below. 

Referring back to the query operation 1008, if the service class 510 is not "EXTERNAL," 
then the operation flow is passed to a determine operation 1012. The determine operation 1012 

25 uses the extracted service class 510 to determine the protocol identifier and the domain name for 
the referenced electronic resource. In an embodiment, the determine operation 1012 is 
performed, at least in part, by the configuration module 509. When the configuration module 
510 is a list mapping each service class 510 implemented on the server cluster 100 to a particular 
protocol idenfifier and domain name, the determine operation 1012 accesses this list, and using 

30 the extracted service class 510 as a reference, locates the associated protocol identifier and 
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domain name. If the service class 510 is "LOCAL," then the determine operation 1012 identifies 
the protocol identifier and the domain name to be the protocol identifier and the domain name 
included within the URL request received by the receive operation 904. That is, the protocol 
identifier and the domain name of the resource referenced within the requested document is the 
5 same as the protocol identifier and the domain name for the requested document. As such, the 
configuration module 509 is not used by the determine operation 1012. After the protocol 
identifier and domain name corresponding to the electronic resource being referenced have been 
identified, the operation flow passes to an append operation 1014. 

The append operation 1014 appends the path 518 specified in the entry 528 of the 
10 associated data structure 508 that corresponds to the extracted link identifier 506 to the protocol 
identifier and domain name identified by the determine operation 1012 for the electronic 
resource being referenced. As such, the append operation 1014 yields the URL corresponding to 
the referenced electronic resource. From the append operation 1014, the operation flow passes to 
the incorporate operation 1016. The incorporate operation 1016 replaces the link tag 410 
15 detected by the examine operation 908 with a client-readable definition (e.g., an href tag) 

specifying the URL either yielded by the append operation 1014 or identified by the identify 
operation 1010 (if service class = external). From the incorporate operation 1016, the operation 
flow of the abstraction process 1000 concludes at the terminate operation 1018. Following 
occurrence of the terminate operation 1018, the operation flow of the management process 900 
20 resumes at the transmit operation 912. 

Referring now to FIG. 1 1, a process 1 100 for establishing ("establishment process") the 
above-described system and processes for preparing an electronic resource for use by a client 
system 108 is shown in accordance with an embodiment of the present invention. The 
establishment process 1 100 is performed using an operation flow beginning with a start 
25 operation 1 102 and concluding with a terminate operation 1114. The start operation 1 102 is 
initiated during development of an electronic resource that contains code corresponding to at 
least one reference link 124 to another electronic resource. From the start operation 1 102, the 
operation flow passes to a define operation 1 104. 

The define operation 1 104 defines the link source file 502 for the electronic resource 
30 being developed. An exemplary link source file 502 is shown and described in more detail in 
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connection with FIG. 6. Further, a sub-process illustrating operational characteristics of the 
define operation 1 104 is shown and described in FIG. 1 1 using dashed lines. This sub-process of 
the define operation 11 04 begins with a start sub-operation 1 104a that is initiated at substantially 
the same time that the operation flow of the establishment process 1 100 is initiated. From the 
5 start sub-operation 1 104a, the sub-process of the define operation 1 104 passes to a declare 

operation 1 104b. The declare sub-operation 1 104b is the operation in which each of the service 
classes 510 that will be implemented on server cluster 100 and relied upon to effectuate a 
reference link 124 are declared in the link source file 502. From the declare sub-operation 
1 104b, the sub-process passes to a first define sub-operation 1 104c. The first define sub- 

10 operation 1 104c is the operation in which each of the link identifiers 418 specified in the 
electronic resource is defined on the link source file 502. Next, the sub-process passes to a 
second define operation 1 104d, in which each of the defined link identifiers 418 are mapped to a 
specific service class 510, a specific path 514 and maybe even an optional query 520. The sub- 
process then concludes at the terminate sub-operation 1 104e and the operation flow of the 

1 5 establishment process 1 1 00 resumes at the compile operation 1 1 06. 

The compile operation 1 106 interprets and compiles the link source file 502 into a format 
recognizable to the resource server 104, This compilation yields two objects - a link 
identification index 506 and an associated data structure 508, both of which are described in 
more detail above. After the link source file 502 has been interpreted and compiled, the 
20 operation flow passes to a save operation 1 108. The save operation 1 108 saves the link 
identification index 506 the associated data structure 508 to memory such that the resource 
server 104 can access these objects in random fashion whenever a client computer 108 requests 
an electronic resource having one or more link tags 410. After these objects are stored to 
memory, the operation flow passes to a first query operation 1110. 

25 The first query operation 1 1 10 is a query operation that, after a predetermined period in 

time, accesses the properties associated with the link source file 502 to determine whether the 
link source file 502 has been revised during a predetermined period in time. As such, during 
each iteration of the first query operation 1110, the properties of the link source file 502 are 
examined to determine if any declarations or definitions contained in the file 502 have been 

30 revised since the last time the file 502 was saved by the save operation 1 108. If the link source 
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file 502 has been revised within this certain predetermined time period, the operation flow is 
passed back to the compile operation 1 106 and continues as previously described. 

If, after this predetermined time period, the link source file 502 is not revised, then the 
operation flow passes to a second query operation 1112, which checks to make sure that the 
5 server cluster 100 is still operational and may be used to serve electronic resources to the client 
computer 108. If the server cluster is operational, the operation flow passes back to the first 
query operation 1110 and continues as previously described. Otherwise, if the server cluster 100 
is not operational, the operation flow concludes at the terminate operation 1114. As noted above, 
it should be appreciated that the link source file 502 may be created and compiled on a 
10 computing system other than the resource server 104 (e.g., in a software development laboratory 
or environment). In this embodiment, the query operation 1 12 and 1 14 are not performed and 
the operation flow passes from the save operation 1 108 to the terminate operation 114. 

The various embodiments described above are provided by way of illustration only and 
should not be construed to limit the invention. Those skilled in the art will readily recognize 

15 various modifications and changes that may be made to the present invention without following 
the example embodiments and applications illustrated and described herein, and without 
departing fi-om the true spirit and scope of the present invention, which is set forth in the 
following claims. For example, the present invention is described herein as abstracting a URL 
for a referenced electronic resource using a link identifier 418. These abstracted URLs are 

20 described as having at least a protocol identifier, a domain name, a path and maybe even a query 
string. However, one of skill in the art will recognize that an abstracted URL may include only a 
protocol identifier and a domain name. As such, the path may also be an optional parameter for 
a URL being abstracted in accordance with an embodiment of the invention. 

Even fiirther, those of ordinary skill in the art will appreciate that the described link 
25 identifiers may be used by the present invention to abstract any type of link that may be 
identifiable to computers within a network environment as specifying a location within the 
environment on which an electronic resource is stored. As such, unique addresses formatted by a 
means other than URL are contemplated within the scope of the present invention. Additionally, 
the link source file 502 is described as being a file that, at creation, is not recognizable to the 
30 resource server 104. However, the link source file 502 may instead be written in a format 
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wherein the file 502 may be interpreted by the resource server 104 without first having to be 
compiled by the compiler 504. For example, without limitation, the link source file may be 
created in C# programming language. 
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